1. How many cycles does it take to fill the pipeline? (Notice that DLXview labels the cycles beginning with zero. To avoid ambiguity, fill in the blank: "In DLXview, the first cycle during which all the pipeline stages are busy is labeled **4**.")
2. How many cycles does it take for the computer to execute the first instruction completely?  **It is out of the pipeline in stage 5**
3. What pipeline stage is the instruction and r6, r7, r8 in during cycle number 5 (i.e., the cycle labeled 5)? **It is in the MEM stage**
4. During which cycle does the the processor begin computing the instruction and r12, r13, r14? (Make sure your answer clearly states "the xth cycle" or "the cycle labeled x").

**The 4th cycle**

1. During which cycle does the the processor finish computing the instruction and r12, r13, r14? (Make sure your answer clearly states "the xth cycle" or "the cycle labeled x"). **The processor finishes computing the instruction at cycle 9 when it leavesthe pipeline**
2. Which registers are being read during cycle 5 (the cycle labeled 5)?

**Registers R13 and R14 are being read**

1. Which registers are being written during cycle 5 (the cycle labeled 5)?

**Register R3 is being written**

1. Where does input to the main ALU come from during cycle 2 (the cycle labeled 2)?

**r1,0x0(r2) is coming from pipeline labeled ID/EX**

1. Where does input to the main ALU come from during cycle 3 (the cycle labeled 3)?

**R4,r5 is coming from pipeline ID/EX through the mux into the ALU**

1. What is the purpose of all of the **nops** at the end of the sample program?

**It is a null instruction pushed through the processor to prevent hazards.**

1. How does the DLX pipeline architecture resolve this conflict?

**The DLX solves this conflict by holding the values in registers while the other instructions are using hardware. The clock prevents values from moving forward until the hardware is complete.**

1. What purpose does it serve?

**Used for branch instructions**

1. Identify all pairs of instructions that have a data dependency. In particular identify all pairs of instructions (not necessarily adjacent) where the result of the second instruction depends directly on the result of the first.

**and r6,r3,r7 depends on sub r3,r4,r5**

**or r8,r9,r3 depends on sub r3,r4,r5**

1. Describe in your own words how the DLX hardware addresses this dependency problem. Your answer should be precise enough to convince me that you understand the mechanism used.

**DLX stores values in pipeline registers. Then the instruction will look in the pipeline register file rather than the basic register file.**

1. Trace through the progress of the fourth instruction in a manner similar to that used in the section above ("**A simple pipelined program**"). There is a "visual bug" or discrepancy that you will notice as you trace through the execution of this program. Identify it.

**The bottom mux directly before the ALU is not showing a connection wire.**

1. Step to cycle 4. Use KSnapshot (or another tool of your choice) to capture the main DLXview window. Print the snapshot and highlight the set of wires that shows how the result of sub r3, r4, r5 is routed directly to the main ALU

![](data:image/png;base64,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)

1. read, describe how you would properly coordinate the reading and writing of the registers.

1. Why must the **add** operation be delayed one cycle? Your answer should consider timing issues and functional units. Be sure to explain why forwarding cannot solve the problem.
2. Describe how hardware can *detect* a load data hazard.
3. Why is the branch delay slot necessary? In other words, what would go wrong if we removed the nop?
4. Suppose you had a smarter compiler. Explain what it could put in the branch delay slot instead of a nop.
5. Write an optimized assembly program incorporating your code adjustments. Your solution must still contain a loop.
6. How many cycles does the original program take to assign the final result to register R6? (In other words, during which cycle is the instruction add r6, r4, r5 in the "write-back" phase?)